<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>[5.2]-杂谈：扯一些PhalApi的前世和今生 | PhalApi(π框架) - PHP轻量级开源接口框架 - 助你创造价值！</title>
    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
    <meta content="yes" name="apple-mobile-web-app-capable">
    <meta content="black" name="apple-mobile-web-app-status-bar-style">
    <meta content="telephone=no" name="format-detection">
    <meta content="email=no" name="format-detection">
    <meta name="Author" content="PhalApi,ecitlm,dogstar">
    <meta name="description" content="[5.2]-杂谈：扯一些PhalApi的前世和今生，PhalApi是一个PHP轻量级开源接口框架，致力于快速开发接口服务。支持HTTP/SOAP/RPC等协议，可用于搭建接口/微服务/RESTful接口/Web Services。我们不断更新，保持生气；为接口负责，为开源负责！并承诺永久免费！">
    <meta name="keywords" content="PhalApi,phalapi,phalapi接口开发,后台接口开发,后台接口开发框架,接口开发,接口框架,开源接口框架,PHP后台接口开发,PHP接口开发,PHP接口框架,PHP后台接口框架,phalapi官网,PHP接口框架,php接口开发框架,php接口开发,php web框架,π框架,π开发框架,π接口框架,π接口开发框架,api接口,php接口,,PHP接口框架,phalapi文档,phalapi wiki,PhalApi文档,phalapi在线文档,phalapi官方文档">

    <link rel="stylesheet" type="text/css" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" media="screen">
    <link rel="stylesheet" type="text/css" href="https://cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.css" media="screen">
    <link rel="stylesheet" href="../css/main.css" />
    <link rel="stylesheet" href="../css/loading_bar.css" />
    <link rel="icon" href="http://webtools.qiniudn.com/dog_catch.png" type="image/x-icon" />
    <script src="../js/pace.min.js"></script>
	
	<!-- 代码高亮 -->
	<link rel="stylesheet" href="../css/highlight.min.css">
	<script src="../js/highlight.min.js"></script>
	<script>hljs.initHighlightingOnLoad();</script>
    
</head>

<body>
    <!-- navbar start -->
    <div class="navbar navbar-default navbar-fixed-top" id="mainnav" role="navigation">
        <div class="container">
            <div class="navbar-header">
                <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target=".navbar-collapse">
                    <span class="sr-only">Toggle navigation</span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                </button>
                <a class="navbar-brand website_name" href="/"><!-- <span>PhalApi</span> --><strong>PhalApi</strong></a>
            </div>
            <div class="navbar-collapse collapse" aria-expanded="false" style="height: 1px;">
                <ul class="nav navbar-nav navbar-right" id="nav_bar">
                    <li><a href="/"><span class="glyphicon glyphicon-home"></span></a></li>
                    <li><a href="http://qa.phalapi.net/">社区</a></li>
                    <li><a href="/download.html">下载</a></li>
                    <li class="active"><a href="/wikis/">文档</a></li>
                    <li><a href="http://www.ituring.com.cn/book/2405">书籍</a></li>
                    <li><a href="http://demo.phalapi.net/">体验</a></li>
                    <li><a href="/about.html">关于</a></li>
                    <li><a href="/donate.html">贡献</a></li>
                    <li><a href="/wikis/en/">English</a></li>
                </ul>
            </div>
            <!--/.nav-collapse -->
        </div>
    </div>
    <!-- navbar end -->


    <div id="content">
        <div class="container">
            <div class="row row-md-flex row-md-flex-wrap">
                <h4><a href="/wikis/%5B5.1%5D-%E6%9E%B6%E6%9E%84%E4%B8%8E%E6%80%9D%E6%83%B3%EF%BC%9APhalApi%E6%A0%B8%E5%BF%83%E8%AE%BE%E8%AE%A1%E5%92%8C%E6%80%9D%E6%83%B3%E8%A7%A3%E8%AF%BB.html">上一章</a>   <a href="/wikis/">文档首页</a>   <a href="/wikis/%5B5.3%5D-%E6%A1%86%E6%9E%B6%E6%80%BB%E7%BB%93%EF%BC%9A%E6%9C%AF%E8%AF%AD%E8%A1%A8%E5%92%8CPHP%E5%BC%80%E5%8F%91%E5%BB%BA%E8%AE%AE.html">下一章</a></h4>
<hr />
<p><em>此篇章与框架技术无关，为课外读物，感兴趣的可以略读一下。</em></p>
<h2>5.2.1 写在前面的话</h2>
<p>记得曾经有一位大主教在自己的墓志铭上写道：</p>
<pre><code>“小时候，我发誓要改变整个世界；
大些了，我努力改变我的祖国；
后来，我想我能改变我居住的这个城市；
直到临死之前才发现，我只能改变自己，从而影响他人，乃至影响整个世界”。</code></pre>
<p>当然，我没有想过要去影响整个世界，我只想尽我自己的所学，为自己，为他人做一些有用的事情。  </p>
<p>正如，最近在thephp.cc站点上面看到的这样一张PPT：</p>
<p><img src="http://webtools.qiniudn.com/20150411005257_30831e386e6cd1c171ba4486c1b5166f" alt="-1" /></p>
<p>我不一定能记住这位国际出名的前辈的名字，但我记住了他的这句话：  </p>
<pre><code>Driven by his passion to help developers build better software.</code></pre>
<h2>5.2.2 然而，要布道，先要践道。</h2>
<p>所以，当我希望把PhalApi框架开源出去时，我这个框架应该是初步完善并可以应用于实际项目开发的，至少我已经切身用过它来进行后台接口项目开发并不断优化重构之。  </p>
<h2>5.2.3 最初框架源于毕业论文的需要</h2>
<p>当年，在进行毕业论文的项目开发时，因为需要用到后台接口。于是乎，便到图书馆和网上查阅整理了很多资料，知识理论包括RESTFull、phprpc、SOAP协议、Aamzon接口服务、WSDL、Web Service等等。  </p>
<p>然而，在实际中我却发现很多人在用PHP开发接口是很简单的，或者说是很粗爆的，如直接使用fopen()函数进行获取接口结果。并且，当我需要去寻找一个可以进行后台接口开发的框架时，居然没找到很好框架支持。基于此，最初的接口框架就在这样的背景和研究下出来了。  </p>
<p>附一下当前毕业论文的相关资料：</p>
<ul>
<li>PhalApi前世： 毕业论文答辩汇报 - 精简版.ppt</li>
<li>PhalApiu前世：毕业论文 - 暗夜在火星 - 修改版.pdf</li>
<li>PhalApi前世文档：zenWS3完全开发手册 - 初稿 - 20130317.pdf</li>
</ul>
<p>可以在  <a href="http://git.oschina.net/dogstar/PhalApi/attach_files">附件</a>  下载上面的资料。  </p>
<h2>5.2.4 最初框架的首次商用和实站</h2>
<p>在毕业后就职的第一家公司中，由于也有接口开发的需要，正好是管理后台 内部系统调用，所以在征得领导同意后，我将我毕业论文所研发的接口框架进行了部署和开发。首次投入了商业用途。<code>^_^</code></p>
<p>并同时整理出了初步的接口框架，也就是PhalApi的前世。</p>
<h2>5.2.5 PhalApi的前世</h2>
<p>最初的框架命名是：zenphpWS3。<br />
原因是zen表示开源、php表示用PHP开发、WS表示Web Service、3表示支持SOAP/HTTP/RPC三种协议以及JSON/XML/ARRAY等多种格式的返回。<br />
更多可以访问我之前的博客： <a href="http://my.oschina.net/u/256338/blog/285184">zenphpWS3：文档&amp;示例&amp;设计&amp;源码</a>  </p>
<h2>5.2.6 又一年的全职接口开发和开源框架学习</h2>
<p>曾经有一年，我负责某个大型游戏项目的后台接口开发，同时提供接口供安卓版、iOS版和PC使用，对后台接口的开发有了更多的实战经验。  </p>
<p>并且，在对很多国外优秀的开源框架的学习和研究后，有了很多的领会，如我个人最为推荐的Phalcon。Phalcon不仅仅在框架方面做得非常优秀，在文档编写方面也是不遗余力的，即使我们不用这个框架，也能从这个框架的文档上吸引很多有用的思想。  </p>
<p>才发现最初提供的接口框架还有很多不成熟的地方。。。</p>
<h2>5.2.7 PhalApi框架开源的前奏</h2>
<p>到后来，在越来越多项目开发的需要下，出于仍然没有很好的接口框架支持（这里补充说明一下：一搜索“php接口开发框架”没有好的结果；二所接触到的框架虽然有支持接口开发，但只是其中一部分）。更为重要的是，项目往往又是如此重要，很担忧所选的框架进行接口开发后遇到问题不知如果在底层修正。  </p>
<p>所以，还是用回了自己的接口开发框架。  </p>
<p>当然，在做项目接口开发的同时，我也有意识地在对接口框架进行完善和重构，并融入框架所需要的特性、原则和模式。如可重用、IoC、5条设计原则、组件等。  </p>
<p>至此，PhalApi接口框架也就慢慢地明朗了。接下来就是：</p>
<h2>5.2.8 PhalApi正式走向开源</h2>
<p>如今，很多大的企业都提供了开放平台，如腾讯开放平台、新浪微博开放平台、优酷开放平台等。与此相比，虽然小应用轻量级App项目的后台接口没有这么大的规模，但也是很有量级上的需求的，正如下面这张图所展示的。 </p>
<p><img src="http://webtools.qiniudn.com/20150411005257_4df8d1c65122c2e46bf09bce0bb5b2b5" alt="222" /></p>
<p>在此大背景下，显然会有更多的应用需要后台接口的支撑，需要进行后台接口的开发，乃至对海量数据和访问的支持、快速扩容升级、一键发布、多端支持等。即使这样，PHP开发人员在接口开发时，仍然会显得有点“随心所欲”，缺少规范和统一，更为重要的是仍然没有发现好的PHP接口开发框架。 </p>
<pre><code>古云此日足可惜，吾辈更应惜秒阴。</code></pre>
<p>所以，此框架通过我多个实际项目应用后，在不断整理重构、精益迭代下走向了开源。<code>^_^</code></p>
<p>希望对你们有所帮助，谢谢。</p>
<p>我们通过这个框架，希望可以（正如文档里面所说的）：</p>
<pre><code>一来，支撑轻量级项目后台接口的快速开发；
二来，阐明如何进行接口开发、设计和维护，以很好支持海量访问、大数据、向前向后兼容等；
三来，顺便分享一些好的思想、技巧和有用的工具、最佳实践。</code></pre>
<p>其中，第一点是直接的也是最表面的，即你通过这个接口框架就可以快速开发了；第二点是更通用的接口开发中的一些好的或者必要的技术支撑和策略；第三点是面向框架级别的，即使你不用这个接口框架，也可以设计研发自己的开发框架，同时也是突破接口开发、超越PHP语言的。  </p>
<p>书不尽言，欢迎多交流，再次谢谢！</p>
<hr />
<h4><a href="/wikis/%5B5.1%5D-%E6%9E%B6%E6%9E%84%E4%B8%8E%E6%80%9D%E6%83%B3%EF%BC%9APhalApi%E6%A0%B8%E5%BF%83%E8%AE%BE%E8%AE%A1%E5%92%8C%E6%80%9D%E6%83%B3%E8%A7%A3%E8%AF%BB.html">上一章</a>   <a href="/wikis/">文档首页</a>   <a href="/wikis/%5B5.3%5D-%E6%A1%86%E6%9E%B6%E6%80%BB%E7%BB%93%EF%BC%9A%E6%9C%AF%E8%AF%AD%E8%A1%A8%E5%92%8CPHP%E5%BC%80%E5%8F%91%E5%BB%BA%E8%AE%AE.html">下一章</a></h4><div style="float: left">
<h4>
<a href="http://qa.phalapi.net/">还有疑问？欢迎到社区提问！</a>
</h4>
</div>
            </div>
        </div>
    </div>

 <!-- 广告位 -->
<div class="grid-wrapper desktop-only">
	<p align="center">
		<a href="http://7xiz2f.com1.z0.glb.clouddn.com/%E6%88%91%E7%9A%84%E5%90%8D%E5%AD%97%E5%8F%AB%EF%BC%9A%CF%80%E6%A1%86%E6%9E%B6%20-%20PhalApi%202016%E5%B9%B4%E5%BA%A6%E5%BC%80%E6%BA%90%E6%80%BB%E7%BB%93%20-%20%E5%AE%98%E6%96%B9%E5%87%BA%E5%93%81.pdf" target="blank"><img width="950" height="100" src="http://7xiz2f.com1.z0.glb.clouddn.com/ad_20170104.png"></a>
		<a href="http://www.itran.cc/" target="blank"><img width="950" height="100" src="http://7xslqv.com1.z0.glb.clouddn.com/images/9/69/b88bc92455dc1239f9a5bf8d72929.png"></a>
		<a href="http://web-tools.phalapi.net/" target="blank"><img width="950" height="100" src="http://7xslqv.com1.z0.glb.clouddn.com/images/7/d0/88f523566c482296aecc43d185ca2.png"></a>
	</p>
</div>

        <!-- footer -->
        <div class="footer">
            <div class="link container ">
                <div class=" col-xs-7 col-sm-7 col-md-7 col-lg-7 ">
                    <h3>PhalApi (π框架)</h3>
                    <p>一个轻量级PHP开源接口框架，专注于接口服务开发，支持HTTP/SOAP/RPC协议，拥有自动生成的在线文档、多种开发语言的客户端SDK包以及可重用的扩展类库，可用于快速搭建微服务、RESTful接口或Web
                        Services。</p>
                    <!-- <p>:</p> -->
                    <span>友情链接:</span>
                    <a href="https://www.phalapi.net/" target="_blank"> PhalApi </a>
                    <a href="http://www.oschina.net/" target="_blank"> 开源中国 </a>
                    <a href="https://www.itran.cc/" target="_blank">艾翻译</a>
                    <a href="http://www.phalconphp.com/en/" target="_blank">Phalcon</a>
                    <a href="https://phpunit.de/manual/3.7/zh_cn/automating-tests.html" target="_blank">PHPUnit</a>
                    <a href="http://www.thoughtworks.com/cn/" target="_blank">ThoughtWorks</a>
                    <a href="mailto:chanzonghuang@gmail.com">友链交换</a>

                </div>
                <div class=" col-xs-5 col-sm-5 col-md-5 col-lg-5 contact_us ">
                    <h3>联系我们</h3>
                    <a href="https://github.com/phalapi/phalapi"><img src="../images/github.png" alt="github" /></a>
                    <a href="http://weibo.com/p/100808d236e99beb645bfb56ed1c37dde9b8bd?k=phalapi%E5%BC%80%E6%BA%90%E6%A1%86%E6%9E%B6&from=501&_from_=huati_topic"><img src="../images/weibo.png"  alt="weibo" /></a>
                    <a href="http://7xslqv.com1.z0.glb.clouddn.com/images/1/b0/894fde762850cb11250253f7d5ede.png"><img src="../images/zfb.png"  alt="zfb" /></a>
                    <a href="https://jq.qq.com/?_wv=1027&k=4A6reum"><img src="../images/qq.png"  alt="qq" /></a>
					<a href="http://git.oschina.net/dogstar/PhalApi"><img src="../images/git-oschina.png"  alt="git-oschina" /></a>
                </div>
                <div class="cls"></div>
                <div class="text-center copy_right"> ©2015-2017 PhalApi All Rights Reserved. <a href="http://www.miitbeian.gov.cn" target="_blank">粤ICP备15028808号</a>

				<script type="text/javascript">var cnzz_protocol = (("https:" == document.location.protocol) ? " https://" : " http://");document.write(unescape("%3Cspan id='cnzz_stat_icon_1255326144'%3E%3C/span%3E%3Cscript src='" + cnzz_protocol + "s4.cnzz.com/z_stat.php%3Fid%3D1255326144%26show%3Dpic' type='text/javascript'%3E%3C/script%3E"));</script>
                </div>
            </div>
        </div>
    </div>


    <a href="https://github.com/phalapi"><img id="gitHub_fllow" style="position: fixed; top: 0; right: 0; border: 0;z-index:9999" src="https://camo.githubusercontent.com/652c5b9acfaddf3a9c326fa6bde407b87f7be0f4/68747470733a2f2f73332e616d617a6f6e6177732e636f6d2f6769746875622f726962626f6e732f666f726b6d655f72696768745f6f72616e67655f6666373630302e706e67" alt="Fork me on GitHub" data-canonical-src="https://s3.amazonaws.com/github/ribbons/forkme_right_orange_ff7600.png"></a>


    <script src="../js/jquery-1.11.1.min.js"></script>
    <script src="../js/bootstrap.min.js"></script>
</body>

</html>